package com.eastfair.venueservice.entity;

import cn.afterturn.easypoi.excel.annotation.Excel;
import cn.afterturn.easypoi.excel.annotation.ExcelEntity;
import java.math.BigDecimal;
import com.baomidou.mybatisplus.annotation.TableName;
import com.baomidou.mybatisplus.annotation.IdType;
import com.eastfair.core.base.entity.Entity;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableField;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import javax.validation.constraints.NotEmpty;
import javax.validation.constraints.NotNull;
import javax.validation.constraints.Size;
import java.time.LocalDateTime;
import java.util.HashMap;
import java.util.Map;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.NoArgsConstructor;
import lombok.ToString;
import lombok.experimental.Accessors;
import static com.eastfair.core.utils.DateUtils.DEFAULT_DATE_TIME_FORMAT;
import com.eastfair.annotation.model.EchoVO;

import static com.baomidou.mybatisplus.annotation.SqlCondition.LIKE;

/**
 * <p>
 * 实体类
 * 服务项明细
 * </p>
 *
 * @author linan
 * @since 2022-07-13
 */
@Data
@NoArgsConstructor
@ToString(callSuper = true)
@EqualsAndHashCode(callSuper = true)
@Accessors(chain = true)
@TableName("vsm_service_item_detail")
@ApiModel(value = "ServiceItemDetail", description = "服务项明细")
@AllArgsConstructor
public class ServiceItemDetail extends Entity<Long> implements EchoVO {

    private static final long serialVersionUID = 1L;
    @TableField(exist = false)
    private Map<String, Object> echoMap = new HashMap<>();
    /**
     * 是否启用（确认状态）：1是 已确认；0否 未确认
     */
    @ApiModelProperty(value = "是否启用（确认状态）：1是 已确认；0否 未确认")
    @TableField(value = "is_enabled")
    @Excel(name = "是否启用（确认状态）：1是 已确认；0否 未确认")
    private Integer isEnabled;

    /**
     * 是否删除：1是；0否
     */
    @ApiModelProperty(value = "是否删除：1是；0否")
    @TableField(value = "is_deleted")
    @Excel(name = "是否删除：1是；0否")
    private Integer isDeleted;

    /**
     * 项目id
     */
    @ApiModelProperty(value = "项目id")
    @TableField(value = "project_id")
    @Excel(name = "项目id")
    private Long projectId;

    /**
     * 子系统id
     */
    @ApiModelProperty(value = "子系统id")
    @TableField(value = "subsystem_id")
    @Excel(name = "子系统id")
    private Long subsystemId;

    /**
     * 租户id
     */
    @ApiModelProperty(value = "租户id")
    @TableField(value = "tenant_id")
    @Excel(name = "租户id")
    private Long tenantId;

    /**
     * 服务项id
     */
    @ApiModelProperty(value = "服务项id")
    @TableField(value = "service_item_id")
    @Excel(name = "服务项id")
    private Long serviceItemId;

    /**
     * 服务分类id
     */
    @ApiModelProperty(value = "服务分类id")
    @TableField(value = "service_category_id")
    @Excel(name = "服务分类id")
    private Long serviceCategoryId;

    /**
     * 服务规格id
     */
    @ApiModelProperty(value = "服务规格id")
    @TableField(value = "service_specs_id")
    @Excel(name = "服务规格id")
    private Long serviceSpecsId;

    /**
     * 服务单价
     */
    @ApiModelProperty(value = "服务单价")
    @TableField(value = "unit_price")
    @Excel(name = "服务单价")
    private BigDecimal unitPrice;

    /**
     * 服务成本
     */
    @ApiModelProperty(value = "服务成本")
    @TableField(value = "cost_price")
    @Excel(name = "服务成本")
    private BigDecimal costPrice;

    /**
     * 附加费
     */
    @ApiModelProperty(value = "附加费")
    @TableField(value = "surcharge")
    @Excel(name = "附加费")
    private BigDecimal surcharge;

    /**
     * 税率
     */
    @ApiModelProperty(value = "税率")
    @TableField(value = "tax_rate")
    @Excel(name = "税率")
    private BigDecimal taxRate;

    /**
     * 展前折扣
     */
    @ApiModelProperty(value = "展前折扣")
    @TableField(value = "pre_exhibition_discount")
    @Excel(name = "展前折扣")
    private BigDecimal preExhibitionDiscount;

    /**
     * 现场折扣
     */
    @ApiModelProperty(value = "现场折扣")
    @TableField(value = "on_site_discount")
    @Excel(name = "现场折扣")
    private BigDecimal onSiteDiscount;

    /**
     * 备注
     */
    @ApiModelProperty(value = "备注")
    @Size(max = 255, message = "备注长度不能超过255")
    @TableField(value = "remark", condition = LIKE)
    @Excel(name = "备注")
    private String remark;


    @Builder
    public ServiceItemDetail(Long id, Long createdBy, LocalDateTime createTime, Long updatedBy, LocalDateTime updateTime, 
                    Integer isEnabled, Integer isDeleted, Long projectId, Long subsystemId, Long tenantId, 
                    Long serviceItemId, Long serviceCategoryId, Long serviceSpecsId, BigDecimal unitPrice, BigDecimal costPrice, BigDecimal surcharge,
                    BigDecimal taxRate, BigDecimal onSiteDiscount, BigDecimal preExhibitionDiscount, String remark) {
        this.id = id;
        this.createdBy = createdBy;
        this.createTime = createTime;
        this.updatedBy = updatedBy;
        this.updateTime = updateTime;
        this.isEnabled = isEnabled;
        this.isDeleted = isDeleted;
        this.projectId = projectId;
        this.subsystemId = subsystemId;
        this.tenantId = tenantId;
        this.serviceItemId = serviceItemId;
        this.serviceCategoryId = serviceCategoryId;
        this.serviceSpecsId = serviceSpecsId;
        this.unitPrice = unitPrice;
        this.costPrice = costPrice;
        this.surcharge = surcharge;
        this.taxRate = taxRate;
        this.onSiteDiscount = onSiteDiscount;
        this.preExhibitionDiscount = preExhibitionDiscount;
        this.remark = remark;
    }

}
